Please AMEND the CLAIMS as follows: 

1. (Previously Presented) In a network device, a method of performing NAT, 
comprising: 

maintaining a plurality of routing tables, each of the plurality of routing tables being 
associated with a different one of a plurality of virtual private networks; 

receiving a packet, the packet including an IP source address and an IP destination 
address, the packet further including information indicating one of the plurality of routing 
tables to route the packet; 

performing NAT on the packet; 

identifying one of the plurality of routing tables to route the packet; 
identifying an entry in the one of the plurality of routing tables using the IP 
destination address; 

routing the packet using the identified routing table entry; 

receiving a default route to a network device providing one or more shared services, 
the default route being advertised by the a-network device providing one or more shared 
services, wherein each of the shared services is available to each of the plurality of virtual 
private networks; and 

updating each of the plurality of routing tables to include the default route to the 
network device providing one or more shared services available to each of the plurality of 
virtual private networks. 

2. (Currently Amended)The method as recited in claim 1, wherein each of the plurality 
of virtual private networks is associated with a different customer. 
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3. (Original) The method as recited in claim 1, wherein the network device is 
associated with an ingress interface of a service provider network. 

4. (Original) The method as recited in claim 1, wherein the network device is 
associated with an egress interface of a service provider network. 

5. (Original) The method as recited in claim 1, wherein the network device is 
associated with a service provider network. 

6. (Previously Presented) In a network device, a method of performing NAT, 
comprising: 

maintaining a plurality of routing tables, each of the plurality of routing tables being 
associated with a different one of a plurality of virtual private networks; 

receiving a packet, the packet including an IP source address and an IP destination 
address, the packet further including information indicating one of the plurality of routing 
tables to route the packet; 

performing NAT on the packet; 

identifying one of the plurality of routing tables to route the packet; 
identifying an entry in the one of the plurality of routing tables using the IP 
destination address; and 

routing the packet using the identified routing table entry; 
wherein performing NAT on the packet comprises: 

translating the IP source address from a private address to a public address when the 
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packet is received from a network device in a private network. 

7. (Previously Presented) In a network device, a method of performing NAT, 
comprising: 

maintaining a plurality of routing tables, each of the plurality of routing tables being 
associated with a different one of a plurality of virtual private networks; 

receiving a packet, the packet including an IP source address and an IP destination 
address, the packet further including information indicating one of the plurality of routing 
tables to route the packet; 

performing NAT on the packet; 

identifying one of the plurality of routing tables to route the packet; 
identifying an entry in the one of the plurality of routing tables using the IP 
destination address; and 

routing the packet using the identified routing table entry; 
wherein performing NAT on the packet comprises: 

translating the IP destination address from a public address to a private address when 
the packet is received from a network device in a public network. 

8. (Currently Amended) The method as recited in claim 7, wherein the network device 
in the public network provides one or more services to each of the plurality of virtual private 
networks. 

9. (Cancelled) 
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10. (Currently Amended) In a network device, a method of performing NAT, 
comprising: 

maintaining a plurality of routing tables, each of the plurality of routing tables being 
associated with a different one of a plurality of virtual private networks; 

receiving a packet, the packet including an IP source address and an IP destination 
address, the packet further including information indicating one of the plurality of routing 
tables to route the packet; 

performing NAT on the packet; 

identifying one of the plurality of routing tables to route the packet; 
identifying an entry in the one of the plurality of routing tables using the IP 
destination address; and 

routing the packet using the identified routing table entry; 

wherein the packet includes an MPLS tag indicating a virtual private network, and 
wherein identifying one of the plurality of routing tables comprises: 

ascertaining the virtual private network from the MPLS tag; and 

identifying the one of the plurality of routing tables associated with the virtual private 
network. 

11. (Original) The method as recited in claim 10, wherein the MPLS tag further 
identifies the network device responsible for performing NAT and routing the packet. 

12. (Previously Presented) In a network device, a method of performing NAT, 
comprising: 

maintaining a plurality of routing tables, each of the plurality of routing tables being 
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associated with a different one of a plurality of virtual private networks; 

receiving a packet, the packet including an IP source address and an IP destination 
address, the packet further including information indicating one of the plurality of routing 
tables to route the packet; 

performing NAT on the packet; 

identifying one of the plurality of routing tables to route the packet; 
identifying an entry in the one of the plurality of routing tables using the IP 
destination address; and 

routing the packet using the identified routing table entry; 

wherein the packet includes an MPLS tag indicating a virtual private network, and 
wherein performing NAT on the packet comprises: 

ascertaining the virtual private network from the MPLS tag; 

identifying an entry in a translation table including the IP source address, the IP 
destination address, and a virtual private network identifier identifying the virtual private 
network; and 

performing NAT on the packet using the entry in the translation table. 

13. (Currently Amended) The method as recited in claim 12, wherein identifying one of 
the plurality of routing tables to route the packet comprises: 

identifying the one of the plurality of routing tables from the entry in the translation 

table. 

14. (Currently Amended) In a network device, a method of performing NAT, 
comprising: 
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maintaining a plurality of sets of routing information, each of the sets of routing 
information being associated with a different one of a plurality of virtual private networks; 

receiving a packet, the packet including an IP source address and an IP destination 
address, the packet further including information indicating one of the plurality of sets of 
routing information to route the packet; 

performing NAT on the packet; 

identifying an entry in one of the plurality of sets of routing information using the IP 
destination address; 

routing the packet using the identified entry; 

receiving a default route to a network device providing one or more shared services, 
the default route being advertised by a the network device providing one or more shared 
services, wherein each of the shared services is available to each of the plurality of virtual 
private networks; and 

updating the plurality of sets of routing information to include the default route to the 
network device providing one or more shared services available to each of the plurality of 
virtual private networks. 

15. (Currently Amended) The method as recited in claim 14, wherein each of the 
plurality of sets of routing information corresponding to each of the plurality of virtual 
private networks is stored in a separate routing table. 

16. (Currently Amended) The method as recited in claim 14, wherein each of the 
plurality of sets of routing information corresponding to each of the plurality of virtual 
private networks is stored in a single routing table, wherein each entry in the routing table 
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includes a VPN identifier identifying the corresponding one of the plurality of virtual private 
networks. 

17. (Cancelled) 

18. (Currently Amended) The method as recited in claim 14, wherein updating the 
plurality of sets of routing information comprises: 

updating a single routing table to include the default route. 

19. (Currently Amended) The method as recited in claim 18, wherein the single routing 
table is dedicated to storing the default route to shared services available to each of the 
plurality of virtual private networks. 

20. (Currently Amended) The method as recited in claim 18, wherein the single routing 
table stores the plurality of sets of routing information. 

21. (Currently Amended) The method as recited in claim 14, wherein updating the sets 
of routing information comprises updating a plurality of routing tables to include the default 
route, each of the plurality of routing tables being associated with a different one of the 
plurality of virtual private networks. 

22. (Currently Amended) A computer-readable medium storing thereon computer- 
readable instructions for performing NAT in a network device, comprising: 

instructions for maintaining a plurality of routing tables, each of the plurality of 
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routing tables being associated with a different one of a plurality of virtual private networks; 

instructions for receiving a packet, the packet including an IP source address and an 
IP destination address, the packet further including information indicating one of the 
plurality of routing tables to route the packet; 

instructions for performing NAT on the packet; 

instructions for identifying one of the plurality of routing tables to route the packet; 

instructions for identifying an entry in the one of the plurality of routing tables using 
the IP destination address; 

instructions for routing the packet using the identified routing table entry; 

receiving a default route to a network device providing one or more shared services, 
the default route being advertised by a the network device providing one or more shared 
services, wherein each of the shared services is available to each of the plurality of virtual 
private networks; and 

instructions for updating each of the plurality of routing tables to include the default 
route to the network device providing one or more shared services available to each of the 
plurality of virtual private networks. 

23. (Currently Amended) A network device adapted for performing NAT, comprising: 
means for maintaining a plurality of routing tables, each of the plurality of routing 

tables being associated with a different one of a plurality of virtual private networks; 

means for receiving a packet, the packet including an IP source address and an IP 

destination address, the packet further including information indicating one of the plurality of 

routing tables to route the packet; 

means for performing NAT on the packet; 
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means for identifying one of the plurality of routing tables to route the packet; 

means for identifying an entry in the one of the plurality of routing tables using the IP 
destination address; 

means for routing the packet using the identified routing table entry; 

means for receiving a default route to a network device providing one or more shared 
services, the default route being advertised by €t the network device providing one or more 
shared services, wherein each of the shared services is available to each of the plurality of 
virtual private networks; and 

means for updating each of the plurality of routing tables to include the default route 
to the network device providing one or more shared services available to each of the plurality 
of virtual private networks. 

24. (Currently Amended) A network device adapted for performing NAT, comprising: 
a processor; and 

a memory, at least one of the processor and the memory being adapted for: 

maintaining a plurality of routing tables, each of the plurality of routing tables being 
associated with a different one of a plurality of virtual private networks; 

receiving a packet, the packet including an IP source address and an IP destination 
address, the packet further including information indicating one of the plurality of routing 
tables to route the packet; 

performing NAT on the packet; 

identifying one of the plurality of routing tables to route the packet; 
identifying an entry in the one of the plurality of routing tables using the IP 
destination address; 
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routing the packet using the identified routing table entry; 

receiving a default route to a network device providing one or more shared services, 
the default route being advertised by a the network device providing one or more shared 
services, wherein each of the shared services is available to each of the plurality of virtual 
private networks; and 

updating each of the plurality of routing tables to include the default route to the 
network device providing one or more shared services available to each of the plurality of 
virtual private networks. 
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